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GRAPHIC DISPLAY CONFIGURATION FRAMEWORK FOR UNIFIED PROCESS CONTROL SYSTEM INTER- 



(57) Abstract: A common process control graphical user interface plant operators, plant maintenance personnel, and management 
is disclosed which provides a real-time interface to both the process and the plant. The common interface is modular in design and 
is capable of supporting various specializations for each user type. Operator consoles are dedicated to each section of the plant and 
include additional functions such as maintenance, configuration, simulation and supervisory information. The unified for common 
graphical interface replaces control room displays filled with single case analog controllers, meters, and digital indicators. The com- 
mon interface addresses the functions that previously were provided by the panel motor start/stop buttons and status indications, chart 
recorders, annunciator panels and subsystem interfaces. From a console, operators manage alarms, adjust the process by entering 
new setpoints or other parameters, "zoom in" on particular portions of the process for details, and utilize other specialized applica- 
tions to work with their batch, advanced control, or business applications. The interface will run in both dedicated and non-dedicated 
modes, will run as a rich client or as part of a browser style interface utilizing web services and will run on workstations, laptops, 
tablet PC's, handhelds, and smart phones. 
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GRAPHIC DISPLAY CONFIGURATION FRAMEWORK FOR 
UNIFIED PROCESS CONTROL SYSTEM INTERFACE 

Related Applications 

[0001] This application is a regular filed application of and claims, for the 

.purposes of priority, the benefit of U.S. Provisional Application Serial No. 60/567,980, 

entitled "Graphical User Interface for Representing, Monitoring, and Interacting with 

Process Control Systems," which was filed on May 4, 2004 and which this application 

hereby expressly incorporates by reference herein in its entirety. This application is also 

related to U.S. Patent Application Serial Number 10/625,481, entitled "Integration of 

Graphic Display Elements, Process Modules and Control Modules in Process Plants," 

which was filed on July 21, 2003, and which published as U.S. Publication No. 

2004/0153804 on August 5, 2004, which, in turn, is a Continuatipn-in-Part of U.S. Patent 

Application Serial No. 10/278,469, entitled "Smart Process Modules and Objects in 

Process Plants," which was filed on October 22, 2002, and which published as U.S. 

Publication No. 2004/0075689 on April 22, 2004, the entire disclosures of which are 

hereby expressly incorporated by reference herein in their entirety. This application is 

also related to U.S. Patent Application Serial Number 10/368,151 entitled "Module Class 

Objects in a Process Plant Configuration System," which was filed on February 18, 2003, 

and which published as U.S. Publication No. 2004/0199925 on October 7, 2004, the 

entire disclosure of which is hereby expressly incorporated by reference herein in its 

entirety. This application is also related to the following patent applications, which are 

being filed as International (PCT) applications on the same date as this application and 

which this application hereby expressly incorporates by reference herein in their entirety: 

"Associated Graphic Displays in a Process Environment" (Any. Docket No. 
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06005/41 1 1 1); "User Configurable Alarms and Alarm Trending for Process Control 
Systems" (Atty. Docket No. 06005/41 1 12); "Integration of Process Modules and Expert 
Systems in Process Plants" (Atty. Docket No. 06005/41 1 13); "A Process Plant User 
Interface System Having Customized Process Graphic Display Layers in an Integrated 
Environment" (06005/41 1 14); "Scripted Graphics in a Process Environment" (Atty. 
Docket No. 06005/41 1 1 5); "Graphics Integration into a Process Configuration and 
Control Environment" (Atty. Docket No. 06005/41 116); "Graphic Element with Multiple 
Visualizations in a Process Environment" (Atty. Docket No. 06005/41 117); "System for 
Configuring Graphic Display Elements and Process Modules in Process Plants (Atty. 
Docket No. 06005/41 118); "Markup Language-Based, Dynamic Process Graphics in a 
Process Plant User Interface" (Atty. Docket No. 06005/41 127); "Methods and Apparatus 
for Modifying Process Control Data" (Atty. Docket Nos. 06005/591622 and 20040/59- 
1 1622); "Methods and Apparatus for Accessing Process Control Data" (Atty. Docket 
Nos. 06005/591623 and 20040/59-11623); "Integrated Graphical Runtime Interface for 
Process Control Systems" (Atty. Docket Nos. 06005/591628 and 20040/59-11628); 
"Service-Oriented Architecture for Process Control. Systems" (Atty. Docket Nos. 
06005/591629 and 20040/59-11629). 

Technical Field 

[0002J A common process control user interface for operators, maintenance 
personnel, management, and others is disclosed. The user interface is capable of . 
supporting specialized graphics for operators, maintenance workers, management, 
simulator engineers, configuration engineers and others, i.e. all user types, as opposed to 
separate interfaces for each user type. The common interface exploits fast and accurate 
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translation of raw data into useful animations, trends and patterns which can help in 
deciding on the actions required to improve the process control. The common interface - 
may be manipulated by the user but includes non-occludable portions such as, for 
example, alarm notifications. 

Background of the Related Art 

[0003] Process control systems are widely used in factories and/or plants in 
which products are manufactured or processes are controlled (e.g., chemical 
manufacturing, power plant control, etc.) Process control systems are also used in the 
harvesting of natural resources such as, for example, oil and gas drilling and handling 
processes, etc. Virtually any manufacturing process, resource harvesting process, 
including agriculture, can be automated through the application of one or more process 
control systems. 

[0004] "Distributed" process control systems, like those used in chemical, 
petroleum or other processes, typically include one or more process controllers 
communicatively coupled to one or more field devices via analog, digital or combined 
analog/digital buses. The field devices, which may be, for example, valves, valve 
positioners, switches and transmitters (e.g., temperature, pressure, level and flow rate 
sensors), are located within the process environment and perform process functions such 
as opening or closing valves, measuring process parameters, etc. Smart field devices, 
such as the field devices conforming to the well-known Fieldbus protocols, such as the 
FOUNDATION™ Fieldbus protocol, may also perform control calculations, alarming 
functions, and other control functions commonly implemented within the controller. 
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[0005] The process controllers receive signals indicative of process 
measurements made by the field devices and/or other information pertaining to the field 
devices and execute a controller application that runs, for example, different control 
modules which make process control decisions, generate control signals based on the 
received information and coordinate with the control modules or blocks being executed in 
the field devices, such as HART and Fieldbus field devices. The control modules in the 
controller send the control signals over the communication lines to the field devices to 
thereby control the operation of the process. 

[0006] Information from the field devices and the controller is usually made 
available over a data highway to one or more other hardware devices, such as operator 
workstations, personal computers, data historians, report generators, centralized 
databases, etc., typically placed in control rooms or other locations away from the harsher 
plant environment. These hardware devices run applications that may, for example, 
enable an operator to perform functions with respect to the process, such as changing 
settings of the process control routine, modifying the operation of the control modules 
within the controller or the field devices, viewing the current state of the process, viewing 
alarms generated by field devices and controllers, simulating the operation of the process 
for the purpose of training personnel or testing the process control software, keeping and 
updating a configuration database, etc. 

[0007] As an example, the DeltaVTM control system, sold by Emerson Process 
Management includes multiple applications stored within and executed by different 
devices located at diverse places within a process plant. A configuration application, 
which resides in one or more operator workstations, enables users to create or change 
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process control modules and download th,ese process control modules via a data highway 
to dedicated distributed controllers. 

[0008] Typically, these control modules are made up of communicatively 
interconnected function blocks, which are objects in an object oriented programming 
protocol that perform functions within the control scheme based on inputs thereto and 
provide outputs to other function blocks within the control scheme. The configuration 
application may also allow a designer to create or change operator interfaces which are 
used by a viewing application to display data to an operator and to enable the operator to 
change settings, such as set points, within the process control routine. Each dedicated 
controller and, in some cases, field devices, stores and executes a controller application 
that runs the control modules assigned and downloaded thereto to implement actual 
process control functionality. 

[0009] The viewing applications, which may be run on one or more operator 
workstations, receive data from the controller application via the data highway and 
display this data to process control system designers, operators, or users using the user 
interfaces, and may provide any of a number of different views, such as an operator's 
view, an engineer's view, a technician's view, etc. A data historian application is 
typically stored in and executed by a data historian device that collects and stores some or 
all of the data provided across the data highway while a configuration database 
application may run in a still further computer attached to the data highway to store the 
current, process control routine configuration and data associated therewith. 
Alternatively, the configuration database may be located in the same workstation as the 
configuration application. 

5 
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[0010] As the number and type of control and support applications used in a 
process control environment have increased, different graphical display applications have 
been provided to enable users to effectively configure and use these applications. For 
example, graphical display applications have been used to support control configuration 
applications to enable a configuration engineer to graphically create control programs to 
be downloaded to the control devices within a process plant. 

[0011] Additionally, graphical display applications have been used to enable 
control operators to view the current functioning of the process plant, or areas of the 
process plant, to enable maintenance personnel to view the state of hardware devices 
within the process plant, to enable simulation of the process plant, etc. However, these 
graphical display applications have, in the past, been created as part of or to support the 
specific applications with which they are associated, and thus are generally limited in 
usefulness to the specific process function for which they were created. For example, it is 
difficult, if not impossible, to use a currently available graphical program created to 
support a control operator in a maintenance, a configuration or a simulation function. 
Conversely, it is difficult, if not impossible to use currently available graphics programs 
designed for a maintenance technician to support a control operator, a configuration 
engineer or in a simulation function. In summary, currently available graphics programs 
are specialized arid not versatile. 

[0012] As a particular example, some process control configuration 
applications presently include a library of template objects, such as function block 
template objects and, in some cases, control module template objects, which are used to 
create a control strategy for a process plant. The template objects have default properties, 
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settings and methods associated therewith and the engineer using a graphical 
configuration application can select these template objects and essentially place copies of 
the selected template objects into a configuration screen to develop a control module. 

[0013] During the process of selecting and placing the template objects into the 
configuration screen, the engineer interconnects the inputs and outputs of these objects 
and changes their parameters, names, tags and other properties to create a specific control 
module for a specific use in the process plant. After creating one or more such control 
modules, the engineer can then instantiate the control module and download it to the 
appropriate controller or controllers and field devices for execution during operation of 
the process plant. 

[0014] Thereafter, the engineer may use a different graphical display creation 
application to create one or more displays for operators, maintenance personnel, etc. 
within the process plant by selecting and building display objects in the display creation 
application. These displays are typically implemented on a system wide basis in one or 
more of the workstations and provide preconfigured displays to the operator or 
maintenance persons regarding the operating state of the control system or the devices 
within the plant. These displays generally take the form of alarming displays that receive 
and display alarms generated by controllers or devices within the process plant, control 
displays indicating the operating state of the controllers and other devices within the 
process plant, maintenance displays indicating the functioning state of the devices within 
the process plant, etc. 
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[0015] However, these displays are generally preconfigured to display, 
information or data received from the process control modules or the devices within the 
process plant. In some known systems, displays are created through the use of objects 
that have a graphic associated with a physical or logical element and that is 
communicatively tied to the physical or logical element to receive data about the physical 
or logical element. The object may change the graphic on the display screen based on the 
received data to illustrate, for example, that a tank is half full, to illustrate the flow 
measured by a flow sensor, etc. However, the graphical displays used for configuration, 
operator control, maintenance and simulation activities now need to be created separately 
from one another using different graphical editors as the separate graphical editors are not 
translatable between the needs of operators, maintenance personnel, configuration 
personnel, simulator personnel and management. 

[0016] Thus, similar to the control configuration application, the display 
creation application may have template graphical display items, such as tanks, valves, 
sensors, operator control buttons like slide bars, on/off switches, etc. which may be 
placed on a screen in any desired configuration to create an operator display, maintenance 
display and the like. When placed onto the screen, individual graphic items may be 
interconnected on the screen in a manner that provides some information or display of the 
inner-workings of the process plant to users. However, to animate the graphic display, 
the display creator must manually tie each of the graphical items to data generated within 
the process plant, such as data measured by sensors or indicative of valve positions, etc. 
by specifying a communication link between the graphic item and the relevant data 
source within the process plant. This process is tedious, time consuming, may be fraught 
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with error and must be carried out separately for process control, maintenance simulator, 
configuration and supervisory personnel. 

(0017] While the control template objects within the control configuration 
application and the display items within the display creation application are convenient 
because they can be copied and used to create many different control modules and 
graphical displays, there is often a need to create numerous of the same control module 
and graphical display for different equipment within the process plant. For example, 
many medium to large sized process plants have numerous instances of the same or 
similar equipment that can be controlled and viewed using the same basic general control 
module and display. 

[0018] To create these numerous control modules and displays, however, a 
general control module or display module is created and this general control or display 
module is then copied for each of the different pieces of equipment for which it is 
applicable. Of course, after being copied, each of the new control or display modules 
must be manually altered in the configuration application to specify the particular 
equipment to which it is attached and all of these control and display modules must then 
be instantiated and downloaded to the process control system. 

[0019] Unfortunately, the control modules and displays items discussed above 
are not modular in any manner. Thus, after being copied, each of the control modules and 
displays must be manually and individually altered using the appropriate configuration 
application to specify the equipment within the plant to which they are to be associated. 
In a plant having many copies of the same type of equipment (i.e., replicated equipment), 
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this process is tedious, time consuming and fraught with operator introduced errors. Still 
further, once programmed, these different control modules and displays are not aware of 
each other. 

[0020] Therefore, to make a change to the control modules once created, the 
engineer or operator must manually make the same change to each of the different control 
modules for the different replicated equipment which, again, is time consuming and 
tedious. The same problem applies for the graphical views created for the different sets 
of replicated equipment within the plant. In other words, once a specific control module 
or a specific graphical view is created (individually or by being copied from a template 
object) and is then tied to a particular set of equipment within the plant, this control 
module or graphical view exists as a separate entity or object within the system without 
any automatic awareness of the other control modules or graphical displays that are the 
same or similar to it. 

[0021] As a result, changes applicable to every one of the control modules and 
graphical displays of a particular type must be made individually on those modules and 
displays. This problem is even more evident when graphical views are created for the 
same equipment but in different functional contexts within the plant, such as for control 
viewing, maintenance viewing and simulation functions. In this case, the graphical views 
are created separately without any knowledge or awareness of one another. 

[0022] Thus, while graphic displays have been provided in and associated with 
different applications used for different general activities performed within a process 
plant, these graphic displays and associated graphic display editors were generally added 
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on at the functional level of the application for which they were created to support. As a 
result, the graphical editors, to the extent they currently exist, have only enabled the user 
to create graphics that support specific functionality need by a specific application. 
Previous process plants did not provide a graphical display editor that could be used by or 
that could support the graphical needs of various or multiple activities being performed in 
the context of plant configuration and support. Thus, for example, a graphical display 
editor used to support or enable control configuration activities only enabled the user to 
create control programs and did not support the needs or functionality of operator or 
maintenance displays. Similarly, graphic display editors used for creating operator views, 
maintenance views, etc. to be provided to a control operator or maintenance technician 
during operation of a plant, did not support functionality associated with configuration 
activities, simulation activities, etc. 

[0023] As a result of the graphic display needs being supported at the individual 
functional levels of the process plant, such as at the control configuration, maintenance 
support, control operator support and simulation support functional levels, different 
displays created by these various editors end up modeling and depicting the same 
components within the plant, which results in the duplication of graphical display efforts 
by various different personnel with the process plant. This duplication of effort is 
manifested not only in the effort needed to create the different graphical displays 
depicting the same process element for different uses, but also in the effort needed to tie 
the graphical elements used in different display applications to the actual hardware or 
software elements within the process plant to which they are associated. 
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[0024] Because graphical support for various process plant activities has been 
provided after the fact, and as part of the actual activity being performed, graphical 
support is not integrated in the plant environment in a manner that enables common 
graphics to be created and used within the plant at the various different functional levels 
of the plant. This non-integration of graphics leads to the graphics actually created for the 
different functions being different from function to function or from application to 
application, which can lead to confusion on the part of users who, while familiar with one 
specific type of graphical display, might occasionally need to view different displays 
associated with different operations or functions within the plant. 

[0025] For example, graphical support for operations, maintenance and 
supervisory functions related to operations and maintenance are typically all different, not 
integrated, involve different techniques and require training. On the other hand, the 
provision of graphical display support at the various different functional levels of the 
plant (e.g. operations, maintenance, management, installation and set-up, etc.) leads to the 
duplication of various graphic support elements, both in creating displays and properly 
connecting the elements within the displays to actual hardware or software elements 
within the plant. 

[0026] As a result, there is a need for common graphics user interface for 
process control systems where the various functional levels that support a process or 
plants, e.g. operations, maintenance, supervisory, etc. are integrated into a single interface 
platform to eliminate duplication involved in employing non-integrated programs and to 
better assist all process control personnel in becoming familiar with the interfaces used by 
their coworkers. Such a common or universal graphics interface should be easily 



12 



WO 2005/107409 



PCTYUS2005/015393 



modified and manipulated by the end users while making some displays, such as alarms 
or other imperative displays, non-occludable. 

Summary of the Disclosure 

[0027] A graphical interface for operators, maintenance personnel, 
management, and others of various functions in a process plant environment is disclosed 
that provides a real-time interface to both the process and the plant. The interface is 
capable of supporting various specializations and functions for each user type. The users 
are relatively free to manipulate their workstations with multiple floating panel displays 
through the use of a configuration database. The configuration database binds data 
sources and events to low level shapes. 

[0028] In an embodiment, the configuration databases of the interface provides 
downloadable displays that allow operators to follow the process being controlled by 
taking advantage of the fast and accurate translation of raw data into useful animations, 
trends and patterns which can help in deciding on the actions required on the part of the 
operator. However, the same interface also provides appropriate displays for a 
maintenance person regarding the process being controlled by the operator and provides 
various types of reporting data for use by management personnel. Simulation and 
configuration displays are also available from the configuration database. All of these 
functions are supported by a single interface platform. 

[0029] In an embodiment, the interface graphics of an operator console is 
extended to include additional functions such as maintenance and supervisory reports. 
The interface can be used an operator station, which may include one or more monitors, a 
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standard or custom keyboard, a sound card, speakers, and a pointing device such as a 
mouse, trackball, and/or touch screen. The disclosed operator graphics interface replaces 
the control room panel board filled with single case analog controllers, meters, gauges 
and digital indicators. 

[0030] In an embodiment, the disclosed interface includes one or more of the 
following functions: panel motor start/stop buttons, status indications, chart recorders, 
annunciator panels and subsystem interfaces. 

[0031] In an embodiment, the disclosed user interface enables operators to 
perform one or more of the following: manage alarms, adjust the process by entering new 
setpoints or other parameters, "zoom in" on particular portions of the process for further 
details, and utilize other specialized applications related to the process being performed 
and controlled. 

[0032] In an embodiment, the disclosed graphical interface can run in both 
dedicated and non-dedicated modes. 

[0033] In an embodiment, the disclosed graphical interface can run as a rich 
client or as part of a browser style interface utilizing web services. 

[0034] In an embodiment, the disclosed graphical interface can run on 
workstations, laptops, tablet PC's, handhelds, and smart phones. 

[0035] In an embodiment, the disclosed interface supports a dedicated mode for 
use in control rooms or any place where the display arrangement needs to be fixed and/or 
access strictly controlled (i.e. kiosk style application environment). 
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[0036] In an embodiment, the configuration capabilities of the disclosed 
graphical interface supports a non-dedicated mode for use by configuration personnel, 
engineers, plant management, and others where flexibility and the richness of the 
interface are dominant features. 

[0037] In an embodiment, the configuration capabilities of the disclosed 
graphical interface supports multiple user interface devices including, but not limited to 
rich clients, web browsers, handhelds, and smart phones. 

[0038] In an embodiment, the disclosed graphical interface supports one or 
more of the following features: integrated voice and video; input techniques such as those 
used in tablet PCs; real-time data services including embedded historian data, alarms, 
events, etc.; external data services; XAML files; access to other service interfaces; 
process graphics including composite structures; class-based control hierarchies; 
integration of control, alarming, and abnormal situation management and prevention; 
integrated batch operator interfaces; integrated advanced control operator interfaces; route 
management; efficiency calculations; optimizations; mass and energy balances; 
integration of third party applications; decoupling of applications from the DeltaV® core 
subsystems; support for multiple data collection systems (DCS); support real-time data 
from multiple systems, e.g. DeltaV® and PRQVOX®; support alarming from multiple 
systems, e.g. DeltaV® and PRO VOX®; support areas on the display that cannot be 
occluded such as alarm banners. 

[0039] In an embodiment, the disclosed graphical interface allows displays and 
other applications to be loaded into a runtime workspace. The runtime workspace 
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provides a safe environment where the various applications can execute. The runtime 
workspace can be customized for each target environment including but not limited to 
smart phones, handhelds, tablets, laptops, workstations, and multi-panel workstations. 

[0040] In an embodiment, the disclosed graphical interface provides an ability 
to build a completely integrated display system. 

[0041] In an embodiment, the disclosed graphical interface provides global 
track binding to data values and events. 

[0042] In an embodiment, the disclosed graphical interface provides an ability 
track to where displays are used in the system. 

[0043] In an embodiment, the disclosed graphical interface provides a complete 
version tracking on the display(s). 

[0044] In an embodiment, the disclosed graphical interface provides an ability 
to link data from other sources. 

[0045] In an embodiment, the disclosed graphical interface provides an ability 
to use data from other sources. 

[0046] In an embodiment, the disclosed graphical interface provides an ability 
to define libraries of reusable displays and display components. 

[0047] In an embodiment, the disclosed graphical interface provides an ability 
to define plant standards, lock said standards, version said standards and easily share said 
standards amongst multiple users of different function levels. 
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[0048] In an embodiment, the disclosed graphical interface provides a means 
for developing safe views for plant personnel to use on their wide variety of devices. . 

[0049] In an embodiment, the disclosed graphical interface provides fully 
scalable graphics with special features for rotation, transparency, etc for accessible to 
multiple users of different function levels. 

[0050] Other features and advantages will be apparent to those skilled in the art 
from the following detailed description with reference to the accompanying drawings and 
appended claims. 

Brief Description of the Drawings 
[0051] Various features of the disclosed unified graphical display 
configurations are illustrated in the accompanying drawings, wherein: 

[0052] Fig. 1 is a block diagram of a distributed process control network 
located within a process plant including operator workstations that implement display 
routines and other applications associated with various functions within the process plant, 
as well as a workstation that provides system level graphical support that may be used to 
create display elements and displays for each of the various functional areas of the plant; 

[0053] Fig. 2 is a logical block diagram illustrating the integration of system 
level graphical support within a process plant control, viewing and simulation system; 

[0054] Fig. 3 is a logical diagram illustrating a configuration environment in 
which graphical elements and displays are created and a runtime environment in which 
graphical elements and displays may be executed; 
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[0055] Fig. 4 is a example of a run time graphical interface workspace capable 
of being customized for various target environments including workstations, multiple 
panel workstations, phones, handheld devices, tablets and laptops; 

[0056] Fig. 5 is a partial view of the graphic interface shown in Fig. 1 
schematically illustrating steps for creating low level shapes and shape composites, 
binding data sources and events to the data sources, creating complete displays, storing 
displays in a configuration database, downloading displays from the configuration 
database and generating a run time loadable view of the configuration database suitable 
for loading into a rich user interface or web browser; 

[0057] Fig. 6 is a schematic illustration of a graphic interface that supports 
multiple data sources including a schematic of a process control module, a graphical 
illustration of a data trend and a spreadsheet or grid data presentation; 

[0058] Fig. 7 is a schematic illustration of the disclosed graphical interface 
supporting data from multiple data sources. 

[0059] Fig. 8 is a .schematic illustration of a graphics editor workspace designed 
in accordance with this disclosure; 

[0060] Fig. 9 illustrates a workspace view of one means for launching the editor 
program illustrated in Fig. 8; 

[0061] Fig. 10 illustrates an explore function of the editor described in Fig. 9. 

[0062] Fig. 1 1 illustrates a disclosed display on a hand-held device such as a 
PDA, smart phone or tablet PC; and 
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[0063] Figs. 12 and 13 illustrate the applicability of the disclosed graphics 
display editor to multi-panel or multi-screen workstations. 

[0064] It should be understood that the Figures are not to scale and that the 
disclosed embodiments are illustrated using graphic symbols, diagrammatic 
representations and fragmentary views. Details may have been omitted which are 
unnecessary for understanding of the disclosed embodiments or which render other 
details difficult to perceive. It should be understood, of course, that this disclosure is not 
limited to the particular embodiments illustrated herein. 

DETAILED DESCRIPTION OF THE 
PRESENTLY PREFERRED EMBODIMENTS 

[0065] Fig. 1 illustrates an example process plant 10 in which system level 
graphical support is provided to various functional areas of the plant 10. As is typical,, the 
process plant 10 includes a distributed process control system having one or more 
controllers 12, each connected to one or more field devices 14 and 16 via input/output 
(I/O) devices or cards 18 which may be, for example, Fieldbus interfaces, Profibus 
interfaces, HART interfaces, standard 4-20 ma interfaces, etc. The controllers 12 are also 
coupled to one or more host or operator workstations 20-23 via a data highway 24 which 
may be, for example, an Ethernet link. 

[0066] A database 28 may be connected to the data highway 24 and operates as 
a data historian to collect and store parameter, status and other data associated with the 
controllers and field devices within the plant 10 and/or as a configuration database that 
stores the current configuration of the process control system within the plant 10 as 
downloaded to and stored within the controllers 12 and field devices 14 and 16. The 
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database 28 may additionally store graphical objects created in the manner described 
herein to provide graphical support within the process plant 10. While the controllers 12, 
I/O cards 18 and field devices 14 and 16 are typically located down within and distributed 
throughout the sometimes harsh plant environment, the operator workstations 20-23 and 
Hie database 28 are usually located in control rooms or other less harsh environments 
easily assessable by controller or maintenance personnel. 

[0067] As is known, each of the controllers 12, which may be by way of 
example, the DeltaV™ controller sold by Emerson Process Management, stores and 
executes a controller application that implements a control strategy using any number of 
different, independently executed, control modules or blocks 29. Each of the control 
modules 29 can be made up of what are commonly referred to as function blocks wherein 
each function block is a part or a subroutine of an overall control routine and operates in 
conjunction with other function blocks (via communications called links) to implement 
process control loops within the process plant 10. 

[0068] As is well known, function blocks, which may be objects in an object 
oriented programming protocol, typically perform one of an input function, such as that 
associated with a transmitter, a sensor or other process parameter measurement device, a 
control function, such as that associated with a control routine that performs PID, fuzzy 
logic, etc. control, or an output function that controls the operation of some device, such 
as a valve, to perform some physical function within the process plant 10. Of course 
hybrid and other types of complex function blocks exist such as model predictive 
controllers (MPCs), optimizers, etc. While the Fieldbus protocol and the DeltaV system 
protocol use control modules and function blocks designed and implemented in an object 
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oriented programming protocol, the control modules could be designed using any desired 
control progranuning scheme including, for example, sequential function block, ladder 
logic, etc. and are not limited to being designed and implemented using the function block 
or any other particular programming technique. 

[0069] In the plant 10 illustrated in Fig. 1, the field devices 14 and 16 
connected to the controllers 12 may be standard 4-20 ma devices, may be smart field 
devices, such as HART, Profibus, or FOUNDATION™ Fieldbus field devices, which 
include a processor and a memory, or may be any other desired type of devices. Some of 
these devices, such as Fieldbus field devices (labeled with reference number 16 in Fig. 1), 
may store and execute modules, or sub-modules, such as function blocks, associated with 
the control strategy implemented in the controllers 12. Function blocks 30, which are 
illustrated in Fig. 1 as being disposed in two different ones of the Fieldbus field devices 
16, may be executed in conjunction with the execution of the control modules 29 within 
the controllers 12 to implement process control, as is well known. Of course, the field 
devices 14 and 16 maybe any types of devices, such as sensors, valves, transmitters, 
positioners, etc. and the I/O devices 18 maybe any types of I/O devices conforming to 
any desired communication or controller protocol such as HART, Fieldbus, Profibus, etc. 

[0070] In the process plant 10 of Fig. 1, the workstations 20-23 may include 
various applications that are used for various different functions performed by the same 
or different personnel within the plant 10. Each of the workstations 20-23 includes a 
memory 31 that stores various applications, programs, data structures, etc. and a 
processor 32 which may be used to execute any of the applications stored in the memory 
31. In the example illustrated in Fig. 1, the workstation 20 is designated as a 
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configuration workstation and includes one or more configuration applications 33 which 
may include, for example, control module creation applications, operator interface 
creation applications and other data structures which can be accessed by any authorized 
configuration engineer to create and download control routines or modules, such as the 
control modules 29 and 30, to the various controllers 12 and devices 16 of the plant 10. 

[0071] The workstation 21 is generally illustrated in Fig. 1 as a control operator 
viewing workstation and includes a number of display applications 34 which may provide 
a control operator with various displays during operation of the process plant 10 to enable 
the operator to view and control what is happening within the process plant 10 or in 
various sections of the plant. The applications 34 may include support applications 34a 
such as control diagnostic applications, tuning applications, report generation applications 
or any other control support applications that may be used to assist a control operator in 
performing control functions. 

[0072] Similarly, the workstation 22 is illustrated as a maintenance viewing 
workstation and includes a number of maintenance applications 35 that may be used by 
various maintenance personnel to view the maintenance needs of the plant 10, to view the 
operating or working condition of various devices 12, 14, 16, etc. Of course, the 
applications 35 may include support applications 35a such as maintenance diagnostic 
applications, calibration applications, vibration analysis applications, report generation 
applications or any other maintenance support applications that may be used to assist a 
maintenance person in performing maintenance functions within the plant 10. 
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[0073] Additionally, the workstation 23 is indicated as a simulation workstation 
which includes a number of simulation applications 36 that may be used to simulate 
operation of the plant 10 or various sections of the plant 10 for any number of purposes, 
including for training purposes, for plant modeling purposes to assist in plant 
maintenance and control, etc. As is typical, each of the workstations 20-23 includes a 
display screen 37 along with other standard peripheral devices, like a keyboard, a mouse, 
etc. 

[0074] Of course, while the various configuration, control, maintenance and 
simulation applications 33-36 are illustrated in Fig. 1 as being located in different 
workstations dedicated to one of those functions, it will be understood that the various 
applications 33-36 associated with these or other plant functions may be located in and 
executed in different workstations or computers within the plant 10, depending on the 
needs and set up of the plant 10. Thus, for example, one or more simulation applications 
36 and control applications 33 may be executed in the same workstation 20-23, while 
different individual simulation applications 36 or different individual control applications 
33 may be executed in different ones of the workstations 20-23. 

[0075] In the past, the development of the different applications used in the 
different functional areas of the plant 10 was performed fairly independently. Thus, the 
development of the configuration applications 33 was not integrated with the simulation 
applications 36, the maintenance applications 35 or the operator control applications 34. 
In fact, in many instances, a plant may have included applications for the different 
functional areas that were developed by different companies or software suppliers, and 
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which were in fact developed to run independently of the other software within the plant 
10. 

[0076] As a result of this independent development and operation of the 
different applications associated with the various functional areas of the plant 10, plant 
personnel were generally required to configure or set up a plant separately at each of the 
configuration, operator control, maintenance and simulation functional levels. In 
particular, the same or different plant personnel generally had to use different programs to 
establish new data structures and graphical displays at each of the functional levels. 
Thus, with respect to Fig. 1, each of the various applications 33-36 the performed 
configuration, control, maintenance and simulation functions generally included or used 
different graphic display editors and database structures to assist the plant personnel in 
performing these configuration, operator control, maintenance and simulation functions. 

[0077] In many instances, these different graphic display editors and databases 
were used to create different graphical displays to depict or model the same sections or 
areas of the plant 10 or the same hardware within the plant 10, and to assist different plant 
personnel to visualize and understand what is happening within the process plant in the 
context of configuration, operator control, maintenance or simulation activities. 

[0078] Because the applications 33-36 and the associated displays for each of 
the various functions within the plant 10 were generally developed and implemented 
independently of one another, sometimes by different people and even different 
companies, the graphical displays created or used in the different functional areas of the 
process plant were not integrated in any consistent or easily understood manner from the 
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standpoint of providing graphical visualization. As a result, the independent creation and 
execution of graphical displays at the various different functional levels of the plant led to 
the graphical displays looking different from function to function, so that there was not 
consistent look and feel to the graphic displays across the functional areas. 

[0079] Additionally, this independent creation led to the duplication of effort in 
creating graphical displays for the same sections or areas of the plant but for different 
functional uses, and required that the graphical displays so created be tied into and 
receive data from the various devices within plant 10, such as the controllers 12 and the 
field devices 14, 16, separately at the functional levels of the plant 10. This fact, in turn, 
required the duplication of database structures to track the same hardware elements for 
the different displays. Thus, for example, in the past, a first application (e.g., one of the 
applications 35) was used to create a maintenance display that illustrates a section of the 
plant 10 for maintenance purposes while a second application (e.g., one of the 
applications 34) was used to create a control operator display that illustrates the same 
section of the plant 10 for control purposes. 

[0080] The displays created separately by these different display editors could 
be quite different in look and feel, making it difficult for a user to switch back and forth 
between the maintenance display and the operator display without becoming easily 
confused or without requiring training on each type of display. Likewise, effort was 
duplicated in creating both displays independently in the different applications 34 and 35, 
and additional effort was expanded to create database structures to separately tie or 
connect the maintenance display and the control operator display to the same hardware 
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elements within the plant 10 to receive sometimes the same or similar data from those 
hardware elements. 

[0081] To alleviate these inefficiencies and to provide for more widely usable 
and understandable graphics within the plant 10, a graphical support layer is provided at a 
system level of the process plant 10 to support the graphical display and data structure 
needs of each of the various functional areas of the plant, including the configuration, 
operator viewing, maintenance viewing, simulation and other functional areas of the plant 
10. 

[0082] This system level of support is depicted diagrammatically in Fig. 2, 
which illustrates a plant operational level 40, a plant functional level 42 and a system 
level 44. As will be understood from Fig. 2, the plant operational level 40 includes the 
controllers 12, field devices 14, 16, etc. which execute the control routines or modules 29 
and 30, as well as other software run within the plant 10 to implement plant operations on 
a day-to-day basis. The plant functional level 42 is depicted as including a configuration 
function block 46, a control function block 47, a maintenance function block 48 and a 
simulation block 49, although other or different functions could be provided as well. 

[0083] The configuration function block 46 implements the configuration 
routines 33 which interface or communicate with components within the plant operational 
level 40 to provide control strategies or control modules thereto. The control function 
block 47 includes the control viewing and other applications 34 and 34a which also 
interface or communicate typically directly with the various physical and logical 
components within the plant operational level 40 to implement operator initiated changes 
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within the plant, to provide information to the operator via control displays 34, to acquire 
data for the control applications 34a, etc. The maintenance function block 48 includes the 
maintenance routines and applications 35 and 35a which interface or communicate with 
various physical and logical components within the plant operational level 40 to 
implement maintenance procedures, to collect maintenance data, to provide maintenance 
data or information to a maintenance person via maintenance displays 35, to run 
diagnostic applications 35a, etc. Likewise, the simulation function block 49 includes 
simulation routines 36 which implement simulations of the plant 10 and which may be 
communicatively coupled to components within the plant operational level 40 to obtain 
data regarding the plant. 

[0084] As illustrated in Fig. 2, the system level support layer 44 ties into and 
supports each of the function blocks 46-49 within the plant functional layer 42 to enable, 
for example, the creation and maintaining of common database and display structures, 
such as software objects, graphical elements and graphical displays for use in the various 
functional areas 46-49. More particularly, the system level support layer 44 includes 
application, database and graphical support elements that enable the graphical activities 
performed in each of the function blocks 46-49 to be integrated together, or to be 
developed using common database structures and graphical elements created at the 
system support layer 44. 

[0085] To provide this system level support, the system support layer 42 may 
include a graphical display editor 50 and a graphical object database 52. The graphical 
editor 50 creates graphical elements 54 and graphical displays 56, while the graphic 
object database 52 stores the elements 54 and displays 56 in a memory accessible by the 
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editor 52 and by the various applications in the blocks 46-49. The database 52 may also 
store other objects 58 and data structures that connect the graphical elements 54 to 
individual hardware and software elements within the plant operational level 40. 
Additionally, the database 52 may store graphical element or display templates or 
primitives that may be used to create further graphical elements or displays. As will be 
understood from Fig. 2, the graphical display elements 54, displays 56 and other database 
structures 58 may be used by in any and all of the functional blocks 46-49 to create and 
use graphics associated with those functional blocks. 

[0086] As will be understood, the system level support block 44 provides a 
manner of integrating the graphics used in the process plant 10 of Fig. 1 in all of the 
functional areas, to thereby reduce or eliminate the necessity of repeatedly creating 
different graphical elements for the same plant equipment in different functional contexts, 
and to make it easy for a user in each of the functional areas 46-49 to tie into data 
associated with the equipment being displayed in graphical views associated with those 
functional areas. As will be understood, the system level support layer 44 may be used to 
provide graphics and database support for multiple applications in each of the functional 
areas 46-49, for different applications in different ones of the functional areas 46-49, etc. 

[0087] Referring again to Fig. 1, the system level support block 44 may be 
implemented using an additional workstation or user interface 60 which may be 
connected to each of the other workstations 20-23. The workstation 60 may generally 
store the graphics editor 50 and database 52 and may store the other elements 54, 56 and 
58 if so desired. Additionally, the workstation 60 maybe communicatively connected to 
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the workstations 20-23 via the databus 24, via separate wired or wireless communication 
connections (illustrated by dotted lines in Fig. 1) or in any other desired manner. 

[0088] In the configuration illustrated in Fig. 1 , the workstation 60 stores and 
executes the display editor 50 to enable a user to create graphical elements and to group 
such elements into one or more graphical displays, both of which are referred to herein as 
display modules. These display modules may be then stored in the database 52 to be 
accessed and used by various ones of the functional blocks 46-49 illustrated in Fig. 2 and 
implemented on the various workstations 20-23. While, for the sake of illustration, the 
functionality of the system level block 44 and the function level blocks 46-49 is 
illustrated as being implemented on different or separate workstations 20-23 and 60 in 
Fig. 1, it will be understood.that any or all of the applications associated with any of these 
. various blocks could be implemented on the same or different workstations or other 
computers within or associated with the process plant 10. Thus, the graphics editor 50 
may be stored in and executed on any of the other workstations 20-23 or on any other 
computer associated with the plant 10 and need not be in a stand-alone or separate 
computer. 

[0089] As discussed above, the system level layer 44 of Fig. 2 implements 
system level display and database objects, which can be used in a variety of the functional 
environments as well as to provide higher level display capabilities. Generally speaking, 
the display objects created at the system level 44 of Fig. 2 can be categorized as graphical 
elements and graphical displays. Graphical elements are generally primitive or low level 
display objects that are associated with a particular physical entity within the plant, such 
as a hardware device like a valve, a sensor, a pump, a controller, etc. Graphical displays 
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are generally made up of a set of interconnected display elements and are used to 
represent and model more complicated sets of hardware within a plant, such as a unit, an 
area, etc. and includes interconnections between different hardware units. Additionally, 
graphical displays may include graphs, charts and other data provided from the plant, 
from other applications, such as diagnostic and business applications running in the 
workstations 20-23 and 60, etc. 

[0090] Fig. 3 generally illustrates the development and use of graphical 
elements and graphical displays in two environments in which these elements and 
displays may exist, in particular, a configuration environment 70 and a runtime 
environment 72. Generally speaking, display objects in the form of graphical elements 74 
(depicted as separate element objects 74a, 74b, etc.) and graphical displays 76 (depicted 
as separate display objects 76a, 76b, etc.) are created in the configuration environment 70 
using, for example, the display editor 50. After being created, the objects 74 and 76 may 
be stored in the database 52. 

[0091] The objects 74 and 76 may be created as class objects, referred to herein 
as display module class objects, which define a generic object not bound or tied to 
specific hardware or logical elements within the process plant. However, class objects 
can be used to create runtime graphical objects having the same basic properties as the 
class objects, but which are tied or bound to specific hardware within the process plant. 
Generally speaking, however, class objects remain tied to the children objects instantiated 
therefrom, so that changes to the class objects can be automatically propagated to the 
children objects, even when these children objects are instantiated within a runtime 
environment. 
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[0092] As illustrated in Fig. 3, each of the graphic element objects 74 includes a 
number of components that make the graphical element useful in many different contexts. 
In particular, each graphical element 74 includes one or more visualizations 77, any 
number of parameters or properties 78, any number of actions or animations 79 which 
may be implemented as scripts or triggers, and bindings 80. Generally speaking, each 
visualization 77 defines the visual properties or elements to be actually displayed on a 
display screen when the graphic element is implemented in the runtime environment 72. 

[0093] Typically, visualizations define a representation of a physical or logical 
device or group of devices, although a visualization could represent other entities. 
Visualization 77 may be implemented in the runtime environment 72 using any desired 
description or programming paradigm that defines the specifics of the graphical depiction 
of an entity. In one embodiment, the visualizations 77 may be implemented using 
PGXML or Avalon controls, which are well known controls provided by Microsoft® and 
which, because they are object based, provide a manner of making the visualizations 
easily implementable in standard Windows type displays and portable between display 
environments. 

[0094] Generally speaking, the parameters and properties 78 define variables or 
other properties such as static or changeable intrinsic properties, associated with the entity 
being depicted by the visualization. Likewise, the actions and animations 79 define 
programs (which may be implemented as scripts), routines or behaviors to be performed 
on or using the visualization 77 when the visualization 77 is depicted on a display screen, 
to provide the visualization with more interesting, understandable or helpful graphical 
properties. In one case, these actions or animations may take the form of changes in 
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color, size (e.g., height and width, line size, fonts, etc.) of various components of the 
visualization, color fills, and animations such as changes in color, rotations, changes in . 
size and scaling, skewing, etc. 

[0095] These actions and animations provide graphical properties as well as 
user interaction properties to the graphical element 74. The bindings 80, which may be 
static or fixed bindings or bindings which use aliases, define the manner in which the 
parameters or properties 78 are to be bound to data, tags or other entities within the 
runtime environment 72 when the graphic element 74 is implemented as part of a display 
in the runtime environment 72. Basically, the bindings 80 for each graphical element 74 
establish the manner in which the graphical element 74 is tied to one or more entities or 
data elements defined elsewhere in the plant environment and thus defines an interface 
between the actual runtime environment 72 and the graphical element 74. 

[0096] As illustrated in Fig. 3, each of the graphic display objects 76 includes 
numerous components, such as a reference to one or more graphic elements 81, connector 
elements 82, actions and animations 83, properties 84 and bindings 85. Generally 
speaking, a graphic display 76 may be a display that depicts the interaction of various 
graphic elements 81 which may be visually connected together with connector elements 
82 representing pipes, lines, conveyor belts, etc. A dotted line in Fig. 3 illustrates a 
reference to one of the graphic elements 74 by the graphic display 76a. It will be 
understood that the graphic display that references a graphic element includes all of the 
properties, parameters, actions and animations, etc. of that graphic element. 
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[0097] Similar to the graphical elements 74, each graphical display 76 may 
include one or more actions or animations associated therewith that perform, for example, 
animations on the display, user interface interactions, data manipulations, etc. Likewise, 
each graphical display 76 may include any number of properties associated with the 
display, and typically these properties define properties of units, areas, or other groups of 
elements depicted within the display. Of course, the bindings 85 define the manner in 
which the graphical display 76 is tied to one or more entities or data elements denned 
elsewhere in the plant environment and thus defines an interface between the actual 
runtime environment 72 and the graphical display 76. 

[0098] Once created, the graphic displays 76 and the graphic elements 74 may 
be bound to and executed in the runtime environment 72 on, for example, any of the 
workstations 20-23 of Fig 1. In particular, after a graphic element 74 or a graphic display 
76 is created as a class object and is stored in the database 52, that element or display may 
be instantiated as an actual runtime object and may be executed in the runtime 
environment 72. 

[0099] As illustrated by the block 86, the instantiation process fills in the 
bindings defined in the objects 74 and 76 in a resolution table that may be loaded with 
proper variable names, tags, aliases etc. within the process plant or process control system 
to provide a specific connection between actual entities within the process plant and the 
display objects or display modules running on a display device within the plant. As part 
of the binding process, the display objects 74 and 76 thereby connect to data sources 
within the process plant as defined by the resolution table to thereby gain access to the 
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plant and to logically and communicatively connect the instantiated display object to the 
process plant 10. 

[00100] As illustrated by the blocks 87, a display element 74 or a graphic 
display 76 can be executed in or as part of a number of different functions within the 
runtime environment 72, including a configuration display, a control operator display, a 
maintenance display and a simulation display, to name but a few. Additionally, the 
display objects 74 and 76 may be used in performing system level functions, e.g., ones 
that use data from various ones of the functional levels depicted in Fig. 2, including for 
example, predictive control or predictive maintenance functions, system level error 
detection, etc. In fact, the displays, once created in the configuration environment 70 and 
stored in the database 52 may be used for a number of different activities. 

[001 01 1 Still further, the display objects 74 and 76 may be executed on any 
desired display or computer hardware, such as a workstation 90, a laptop computer 91, a 
handheld device 92, like a personal data assistant (PDA), a telephone device, etc., or any 
other specialty display 93, such as a large screen display having multiple monitors, etc. If 
desired, a single graphic display 76 may be layered to include one or more views, such as 
configuration view, an operator view, a maintenance view and a simulation view. 
Alternatively, separate graphical displays 76 may be configured to provide these separate 
views using the same or similar graphical elements 81, to provide a consistent look and 
feel across displays created for these various functions. 

[0100] As illustrated by the block 95, to be ported to the runtime environment 
72, a graphical element 74 or a graphical display 76 may be copied or instantiated, and 

34 



WO 2005/107409 



PCT/US2005/015393 



loaded onto the runtime machine. Generally speaking, it is desirable that the display 
object 74 or 76 be bound to the runtime environment 72 only when called up or actually 
executed on a runtime machine, which is referred to herein as runtime binding. That is, 
the resolution table for each of the instantiated objects is only filled in or bound to the 
runtime environment when the display object is actually running or being executed in a 
runtime computer. This procedure assures that the display object including its 
visualizations, controls, scripts, etc. only executes and thereby uses processing power 
when the visualization(s) of the object are actually being rendered on a display screen. 

[01 01] In other words, the display obj ect is preferably only bound to the 
runtime environment 72 when that object is actually running on a runtime computer. 
Thus, the display objects 74 and 76 may be intermittently connected to the runtime 
environment 72 in a manner defined by the activities of the users viewing the 
visualizations created by these objects. In particular, these objects may be bound to a 
runtime environment 72 at the times at which they are required to be viewed, and may be 
unbound or released when not being viewed by a user, such as when a user niinimizes or 
closes a screen in which these objects are providing a visualization. 

[0102] The display objects 74 and 76 are thus simply objects which may be 
created in a stand-alone environment, i.e., the configuration environment 70, but which 
may be tied or connected with other objects or data structures defined within the process 
plant or any application running within the process plant environment, including, for 
example, objects or data structures defined in any control, simulation, maintenance, or 
configuration environment. Furthermore, once created, the display objects 74 and 76 may 
be definitely bound to these physical or logical process entities directly, via direct 
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references, variables or tags defined a resolution table, or indirectly through the use of 
alias names, variables and parameters, which may be resolved either when the display 
object 74 or 76 is downloaded or instantiated within the a runtime environment 72, or in 
some cases, when the display object 74 or 76 is actually running within the runtime 
environment 72. 

[01 03] The display editor 50 may enable the display objects 74 and 76 to be 
created at various levels of detail, to enhance the ease of use and the versatility of the 
display objects 74 and 76. For example, graphical elements 74 may be created first to 
define the properties and operations of more primitive physical and logical entities, and 
graphical displays 76 may then be created by interconnecting one or more graphical 
elements 74 to create higher level or more complicated displays depicting more 
complicated physical or logical entities, or groups of physical or logical entities. 

[01 04] Fig. 4 is an example of a display 1 10 that includes a lower alarm banner 
1 1 1 which is not occludable. The display 1 10 also includes a configuration banner 112 
that may extend along the vertical edge of the display 1 10 as well. The positions of the 
alarm banner 1 1 1 and configuration banner 1 12 are clearly interchangeable and can be 
disposed on other parts or aspects of the display 110. The display 1 10, as shown, 
includes three main display sections including a notification section 113, a main section 
1 14 and an additional section 115 which may include loadable faceplates, trends and 
other viewing options. The notification section 1 13 is used primarily for notifications 
applicable to operators, maintenance people and supervisory personnel. The main display 
1 14 may include a graphic display of an equipment module or the overall system (e.g., 
see Fig. 3 below) or may include data in numerical, verbal or graphical form. It is 
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important that the alarm banner 1 1 1 not be occludable as process control alarms and their 
notifications would be important to all personnel, in addition to operator personnel. In an 
embodiment, the alarm banner is not scalable or moveable. However, movement of the 
alarm banner 111 may be useful to non-operating personnel who are less concerned with 
alarm banners than managers, maintenance and configuration engineers. 

[0105] The configuration function 112 of the display 110 enables a user to 
configure the display 1 10 as an operation control display, as a maintenance display, as a 
configuration display, as a simulation display or as a display intended for management 
personnel or, a combination of any one or more of these as discussed below. Further, the 
displays disclosed herein may be shown on a one monitor workstation, a multiple monitor 
workstation, a PDA device, a phone or a tablet PC type of device. 

[01 06] The configuration of a display 1 1 0 in accordance with this disclosure 
includes the creation of low level shapes and shape composites 77-80 (see Fig. 3), the 
binding of data sources and events to those data sources as shown at 86 in Fig. 3, the 
creating of complete displays 110, the storing of displays 81-85 in a configuration 
database, the downloading of displays from the configuration database and the generation 
of run time loadable views of the configuration database for loading into a rich user 
interface or a web browser. An example of this is illustrated in Fig. 5 whereby run time 
functions are accessible from the configuration banner 112 and include display loading, 
run time loading, and binding or connection to data sources. Also accessible from the 
configuration banner 1 12 or run time simulation, as backed objects and predicated faults. 
The arrows 1 17, 1 18 are intended to represent the downloading of various scripts from 
the configuration database, which is accessible from the configuration banner 1 12. 
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[0107] Turning to Fig. 6, a modified display 1 10a is shown, with the non- 
occludable alarm banner 1 1 1 in primary or main displays 1 14a, 1 14b and 1 14c. In 1 14a, 
the schematic illustration of part of an equipment module is shown including a pump 121, 
control valve 122 and accumulation tank 123. As the tank is being rilled, a data table 124 
indicates the way to fill the tank 123. However, additional information may be necessary 
and, accordingly, the display 1 14b includes a graphical presentation 125 of the filling of 
the tank 123 and the display 1 14c includes either a spreadsheet or grid 126 showing the 
ongoing data accumulation in numerical form. In this way, the displays may be arranged 
in increasing levels of detail starting from overview displays working down to detailed 
displays which focus on a single aspect of the system. These and other displays may be 
easily configured using the disclosed interface and other variations will be apparent to 
those skilled in the art, some examples of which are discussed below. 

[0108] Turning to Fig. 7, the display graphic software of this disclosure is 
interchangeable with other data sources and programs including the assignees own 
DeltaV® Software, OVATION® Software, PROVOX® Software, and Open Process 
Control (OPC) Software. The graphic display interface disclosed herein is also able to 
communicate with competing databases and software as shown in Fig. 7. 

[0109] Fig. 8 is an example of a graphics display 1 10b under design for an 
operator is indicated by the button 151 that has been activated in the lower tool bar 152. 
The graphics hierarchy view 153 is intended to display the graphic object hierarchy for 
the display 1 1 0b. The property view 154 initially displays document property and then 
changes to display properties for newly chosen tools or currently selected objects as the 
display 1 10b is being designed. A pallet view 155 displays multiple pallets of process 
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elements 156a-156d. A list of external references used in the display 1 10b can be found 
in the bindings view shown at 157. For every display or element a user creates or 
modifies, a separate document window will be opened with the name of the file appearing 
in the title bar. 

[0110] The display editor shown in Fig. 8 also includes the following features. 
The menu 171 includes all of the user commands that can be applied to a particular 
graphic element. The tool bar 172 includes shortcuts to various menu commands. The 
graphics hierarchy 153 includes two elements including a tree view 153a and a list view 
153b. The properties view lists the intrinsic properties and events of a particular graphic 
element. The main screen 174 is the main editing area. The pallet 155 lists the various 
graphic elements 156a-156d that are defined in the system. The interface shown in Fig. 8 
also includes a horizontal ruler 175 and a vertical ruler 176. The embodiment illustrated 
in Fig. 8 can support five layers including an operation layer 151, a maintenance layer 
177, a configuration layer 178, a simulation layer 179 and supervisory or management 
layer 180. More or less of all of these layers are functions can be utilized. In addition, a 
training layer may also be utilized. 

[0111] Fig. 9 is an example of one means for launching the graphics program 
shown in Fig. 8. Fig. 10 is a partial view of a screen showing various displays that have 
been created and stored in various files of the database. When a "display" 158 is selected, 
the files 159, 160 will then appear in the main screen 161 as shown in Fig. 10. 

[0112] Turning to Fig. 1 1 , a sample display 1 1 0b is shown that could be used 
with a PDA, tablet PC or smart phone type of device. The graphics display editor 



39 



WO 2005/107409 



PCT/US2005/015393 



illustrated above in connection with Figs. 1-10 can be used on these types of hand-held 
devices. 

[01 13] Further, as noted above, the above-described display editor can be 
utilized in multi-screen workstations such as those illustrated in Figs. 12 and 13. The 
display shown at 1 10c- 1 lOh can all be configured for operations or process control, 
maintenance, configuration, simulation or supervisory personnel. Various displays 110c- 
11 Oh can individually be process control, maintenance, simulation, configuration or 
supervisory displays or each individual display panel 1 10c-l 1 Oh can be combinations of 
any of the various functions that are supportable by the graphics display editor. Thus, the 
disclosed system provides multiple functional displays on a single display system for a 
type workstation or a hand-held device as well as multiple display workstations. 

[01 1 4] While only certain embodiments have been set forth, alternative 
embodiments in various modifications will be apparent from the above description to 
those skilled in the art. These and other alternatives are considered equivalents and 
within the spirit and scope of this disclosure. 
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What is Claimed is: 

1 . An integrated graphical user interface for a process control 

environment, the interface comprising: 

interface graphics and separate functions for operations, maintenance 
configuration, simulation and management functions of a process plant, 

real-time interfacing functions for operations, maintenance 
configuration, and simulation functions, 

the interface providing real-time display more than one of operations, 
maintenance, configuration and simulation functions. 

2. The interface of claim 1 further comprising translation of raw 
data into operational animations and operational trends and graphical displays of said 
operational animations and operational trends. 

3 . The interface of claim 2 further comprising graphical 
presentations of maintenance requests, maintenance reports and supervisory reports. 

4. The interface of claim 1 further comprising one or more of the 
following functions: panel motor start/stop buttons, status indications, chart 
recorders, annunciator panels, subsystem interfaces and combinations thereof 

5 . The interface of claim 1 further comprising one or more of the 
following functions: alarm management, process parameter adjustment by entry of 
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process parameters, zoom in viewing of portions of the process for enhanced detail 
viewing, utilization of specialized applications related to the process. 

6. The interface of claim 1 wherein the interface can run in 
dedicated and non-dedicated modes. 

7. The interface of claim 1 wherein the interface can run as a rich 
client or as part of a browser style interface utilizing web services. 

8. The interface of claim 1 wherein the interface can run on one or 
more of a workstation, a laptop, a PDA, and a smart phone. 

9. The interface of claim 1 wherein the interface supports a 
dedicated mode for a fixed display arrangement. 

10. The interface of claim 1 wherein the interface supports a non- 
dedicated mode for use by configuration personnel. 

1 1 . The interface of claim 1 wherein the interface supports multiple 

user interface devices. 

12. The interface of claim 1 wherein the interface supports one or 
more of: integrated voice and video; real-time data services; external data services; 
XML files; access to other service interfaces; composite structure process graphics; 
class-based control hierarchies; integration of control, alarming, and abnormal 
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situation management and prevention; integrated batch operator interfaces; integrated 
advanced control operator interfaces; route management; efficiency calculations; 
optimizations; mass and energy balances; integration of third party applications; 
multiple data collection systems (DCS) and combinations thereof. 

13 . The interface of claim 1 wherein the interface receives displays 
and other applications to be loaded into a runtime workspace. 
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14. An integrated graphical interface providing seamless graphical 
displays for operation, maintenance, configuration, and simulation functions on 
multiple workstations of a control system, the interface comprising: 

tracking functions for tracking which displays are used on which 
workstations in the system, and 

the interface providing real-time display more than one of operations, 
maintenance, configuration and simulation functions. 

15. The graphical interface of claim 14 further comprising a linking 
function for linking data from outside sources. 

16. The graphical interface of claim 14 further comprising means 
for using data from outside sources. 

17. The graphical interface of claim 14 further comprising means 
for defining plant standards, means for locking said plant standards, and means for 
distributing said plant standards amongst multiple workstations of the system. 

18. The graphical interface of claim 14 further comprising scalable 

graphics. 

19. A machine readable medium having instructions stored thereon 
that, when executed, cause a machine to: 
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provide seamless graphical displays for operations, maintenance, 
configuration, and simulation functions on multiple workstations of a control system 
and providing real-time display more than one of operations, maintenance, 
configuration and simulation functions, 

provide tracking functions for tracking which displays are used on 
which workstations in the system, 

provide real-time interfacing functions for operation control and 

maintenance personnel. 

20. The machine readable medium of claim 1 9 having instructions 
stored thereon that, when executed, cause the machine to provide fully scalable 
graphics with abilities to rotate the graphics and make portions of the graphics 
transparent. 
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